package org.example.repository;

import org.example.entity.DeviceType;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Optional;

/**
 * 设备类型数据访问接口
 */
@Repository
public interface DeviceTypeRepository extends JpaRepository<DeviceType, Long> {
    
    /**
     * 根据名称查找设备类型
     */
    Optional<DeviceType> findByName(String name);
    
    /**
     * 根据名称模糊查询设备类型
     */
    @Query("SELECT dt FROM DeviceType dt WHERE dt.name LIKE %:name%")
    List<DeviceType> findByNameContaining(@Param("name") String name);
    
    /**
     * 统计设备类型使用次数
     */
    @Query("SELECT COUNT(d) FROM Device d WHERE d.deviceTypeId = :deviceTypeId")
    long countDevicesByType(@Param("deviceTypeId") Long deviceTypeId);
}
